/*
 * SPDX-FileCopyrightText: 2022-2025 Espressif Systems (Shanghai) CO LTD
 *
 * SPDX-License-Identifier: Apache-2.0 OR MIT
 */

#pragma once

/**
 * @file regi2c_saradc.h
 * @brief Register definitions for analog to calibrate initial code for getting a more precise voltage of SAR ADC.
 *
 * This file lists register fields of SAR, located on an internal configuration
 * bus. These definitions are used via macros defined in regi2c_ctrl.h, by
 * function in adc_ll.h.
 */

#define I2C_SAR_ADC            0X69
#define I2C_SAR_ADC_HOSTID     0

#define ADC_SAR1_INITIAL_CODE_LOW_ADDR          0x0
#define ADC_SAR1_INITIAL_CODE_LOW_ADDR_MSB      0x7
#define ADC_SAR1_INITIAL_CODE_LOW_ADDR_LSB      0x0

#define ADC_SAR1_INITIAL_CODE_HIGH_ADDR         0x1
#define ADC_SAR1_INITIAL_CODE_HIGH_ADDR_MSB     0x3
#define ADC_SAR1_INITIAL_CODE_HIGH_ADDR_LSB     0x0

#define ADC_SAR1_SAMPLE_CYCLE_ADDR              0x2
#define ADC_SAR1_SAMPLE_CYCLE_ADDR_MSB          0x2
#define ADC_SAR1_SAMPLE_CYCLE_ADDR_LSB          0x0

#define ADC_SAR1_DREF_ADDR                      0x2
#define ADC_SAR1_DREF_ADDR_MSB                  0x6
#define ADC_SAR1_DREF_ADDR_LSB                  0x4

#define ADC_SAR2_INITIAL_CODE_LOW_ADDR          0x3
#define ADC_SAR2_INITIAL_CODE_LOW_ADDR_MSB      0x7
#define ADC_SAR2_INITIAL_CODE_LOW_ADDR_LSB      0x0

#define ADC_SAR2_INITIAL_CODE_HIGH_ADDR         0x4
#define ADC_SAR2_INITIAL_CODE_HIGH_ADDR_MSB     0x3
#define ADC_SAR2_INITIAL_CODE_HIGH_ADDR_LSB     0x0

#define ADC_SAR2_SAMPLE_CYCLE_ADDR              0x5
#define ADC_SAR2_SAMPLE_CYCLE_ADDR_MSB          0x2
#define ADC_SAR2_SAMPLE_CYCLE_ADDR_LSB          0x0

#define ADC_SAR2_DREF_ADDR                      0x5
#define ADC_SAR2_DREF_ADDR_MSB                  0x6
#define ADC_SAR2_DREF_ADDR_LSB                  0x4

#define I2C_SARADC_TSENS_DAC                    0x6
#define I2C_SARADC_TSENS_DAC_MSB                0x3
#define I2C_SARADC_TSENS_DAC_LSB                0x0

#define ADC_SAR1_ENCAL_REF_ADDR                 0x7
#define ADC_SAR1_ENCAL_REF_ADDR_MSB             0X4
#define ADC_SAR1_ENCAL_REF_ADDR_LSB             0X4

#define ADC_SAR1_ENCAL_GND_ADDR                 0x7
#define ADC_SAR1_ENCAL_GND_ADDR_MSB             0x5
#define ADC_SAR1_ENCAL_GND_ADDR_LSB             0x5

#define ADC_SAR2_ENCAL_REF_ADDR                 0x7
#define ADC_SAR2_ENCAL_REF_ADDR_MSB             0x6
#define ADC_SAR2_ENCAL_REF_ADDR_LSB             0x6

#define ADC_SAR2_ENCAL_GND_ADDR                 0x7
#define ADC_SAR2_ENCAL_GND_ADDR_MSB             0x7
#define ADC_SAR2_ENCAL_GND_ADDR_LSB             0x7

#define I2C_SAR_ADC_DTEST_VDD_GRP1              0x9
#define I2C_SAR_ADC_DTEST_VDD_GRP1_MSB          0x3
#define I2C_SAR_ADC_DTEST_VDD_GRP1_LSB          0x0

#define I2C_SAR_ADC_ENT_VDD_GRP1                0x9
#define I2C_SAR_ADC_ENT_VDD_GRP1_MSB            0x4
#define I2C_SAR_ADC_ENT_VDD_GRP1_LSB            0x4
